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DOCKING DEVICE CLASS SYSTEM AND METHOD 

La Vaughn F. Watts, Jr. 

BACKGROUND OF THE INVENTION 
COPYRIGHT NOTICE 

A portion of the disclosure (particularly the drawings) of this patent document 
contains material which is subject to copyright protection. With respect to those 
aspects of this patent document of which the present applicant and/or assignee is the 
copyright owner, the copyright owner has no objection to the facsimile reproduction 
by anyone of the patent document or the patent disclosure, as it appears in the Patent 
and Trademark Office patent file or records, but otherwise reserves all copyright or 
rights whatsoever. 

Field of the Invention 
Description of the Related Art 

Data processing systems are systems that manipulate, process, and store data. 
Personal computer systems constitute well-known examples of data processing 
systems. 

By convention, personal computer systems are typically "classed" — on the 
basis of size, weight, and portability ~ as either "stationary" computer systems or 
"portable" computer systems. "Stationary" computer systems are so classed because 
of their bulky size and weight. Examples of stationary computer systems are desktop 
computer workstations - so named due to the fact that, although large, such computer 
systems can generally be supported by an office desk. Stationary computer systems 
generally consist of four main components: a computer case, a large CRT monitor, a 
mouse, and a full-size computer keyboard. 
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Stationary computer systems tend to be extremely powerful, due in part to the 
extremely large size of their computer cases. The larger case sizes provide many 
cubic inches of space into which many powerful computing devices can be placed. In 
addition, the larger case sizes of stationary computer systems improve cooling 
properties, and the fact that such computer systems are stationary allows them to be 
driven with large amounts of AC wall-socket power. Lastly, stationary computer 
systems can utilize extremely large monitors and full-size keyboards, allowing for 
very high resolution and ease of use. 

"Portable" computer systems are so classed because their size, weight, and 
construction allows them to be easily (relative to stationary computer systems) 
transported. A portable computer system almost always has a display screen, mini- 
keyboard, a mini-pointing device which functions as a mouse, a computer processor 
and associated memory, and communications device contained in one case. By 
convention, portable computer systems are subclassed as laptop computer systems 
(e.g., 10-20 pounds), notebook computers (similar in physical size to a paper 
notebook, but which usually weigh 5-8 pounds), and subnotebook computers (slightly 
smaller than notebooks, and which generally weigh 2-5 pounds). 

Portable computer systems tend to be have relatively powerful processors, but 
generally have significantly less power and ease of use than that available with 
stationary computer systems. Reasons for such lesser power and ease of use are that 
the smaller cases of portable computer systems do not allow for the same the number 
and size of computing devices which can be present in stationary computer systems, 
the smaller case sizes do not allow for as effective heat management as available in 
stationary computer systems, and the fact that the portable computer systems must 
often run on battery power limits what components portable computer systems can be 
utilize. In addition, the smaller screen size and mini-keyboards utilized in desktop 
computer systems generally are less easy to use than their full-size counterparts 
available in stationary computer systems. 

As noted, portable computer systems tend to have relatively powerful 
processors (generally comparable to mid-range stationary computer systems), but the 
lack of supporting components tend to make such portable computer systems less 
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powerful and less easy to use than stationary computer systems. In the relatively 
recent past, original computer manufacturers (OEMs - producers of portable and 
stationary computer systems) have begun to produce "docking stations," which are 
used to create hybrid systems which allow portable computer system owners to utilize 
the relatively powerful processors of their portable computer systems in a stationary 
computer system environment. It is to be understood that as used herein, the term 
"docking station(s)" is meant to include all devices in the art recognized to provide 
docking functions (e.g., the term "docking stations" is meant to include not only 
devices formally referred to as docking stations but also port replicators, advanced 
port replicators, docking apparatuses - that is, generally any device recognized to 
perform some type of docking function). 

A docking station is a device in which a portable computer can be "docked" - 
electrically and logically connected such that the portable computer system can take 
advantage of additional computational devices either resident in or connected with the 
docking station. The docking station typically contains slots for expansion cards, 
bays for storage devices, and connectors for peripheral devices, such as printers and 
monitors. Once a portable computer system is docked in a docking station, the 
resulting hybrid system functions essentially as a stationary computer system. 
Accordingly, docking stations provide the power of stationary computer systems to 
owners of portable computer systems. In addition, the docking station provides 
owners of notebook computer systems with the ability to use a full-size keyboard and 
monitor when the notebook computer is docked. 

It is significant for the present discussion that there are no "standards" for 
docking stations. A "standard" is a defined way for accomplishing certain tasks. 
(Standards can be either "de facto" standards (something that has become a standard 
not because it has been approved by a standards organization, but because it is widely 
used and recognized by an industry as being standard) or "de jure" standards 
(standards expressly created by standards-setting bodies expressly for the purpose of 
establishing the standard)). For example, an electrical standard for docking might 
specify the currents, voltages, and timing signals associated with docking; a "form 
factor" standard for docking might define the size and shape of physical connectors to 
mate two different devices to be docked; and a logical standard (or protocol) for 
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docking might define the logical sequence in which two different functional devices 
are to exchange information. However, no such docking standards exist in the art. 

At present, docking stations are essentially proprietary creations of individual 
OEMs, which means that consumers can generally only use systems sold by one 
5 particular OEM. That is, the fact that no significant docking standards currently exist 
generally means that consumers must buy a docking station produced by the company 
that produced the consumers' portable computer systems. 

When standards exist, systems can be "open" which means that consumers can 
"mix and match" among various computer manufactures. When standards do not 

10 exist, systems are proprietary. Although counterintuitive, it is preferable for all 

parties involved that standards exist. Consumers benefit because they are not tied to 
one particular OEM, and thus market competition exists, thereby making computing 
devices made under standard more affordable. In addition, counterintutively, it has 
been found that OEMs benefit in that consumers tend to buy more of computing 

1 5 devices made under standard, and in fact OEMs - even those OEMs who previously 
had a near-monopoly position - generally tend to sell more product made under 
standard. 

In light of the foregoing, it is apparent that a need exists for a method and 
system which essentially give rise to an attractive, simple, and competitive way to 
20 standardize docking. However, insofar as OEMs have become accustomed to the 

freedom to innovate currently available under the proprietary systems, it is preferable 
that the method and system preserve such freedom to innovate. 

SUMMARY OF THE INVENTION 

The inventors named herein have devised a method and system which provide 
25 an attractive, simple, and competitive way to standardize docking in such a way that 
the freedom to innovate currently available under proprietary systems is substantially 
preserved. 

In one embodiment, a method includes but is not limited to detecting a 
docking device class circuit present on a bus, and obtaining a description of at least 
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one device in a docking station from the docking device class circuit. In one 
embodiment the method further includes but is not limited to controlling the at least 
one device via commands appropriate to the bus. 

In one embodiment, circuitry is utilized to effect the foregoing-described 
5 method. In addition to the foregoing, a related docking station having a docking 
device class circuit is described. 

In one embodiment, a program product includes but is not limited to program 
code for detecting a docking device class circuit present on a bus, program code for 
obtaining a description of at least one device in a docking station from the docking 
10 device class circuit, and signal bearing media bearing said program code for detecting 
and said program code for obtaining. In one embodiment the program product 
further includes but is not limited to the signal bearing media further bearing program 
code for controlling the at least one device via commands appropriate to the bus. 

The foregoing is a summary and thus contains, by necessity, simplifications, 
15 generalizations and omissions of detail; consequently, those skilled in the art will 
appreciate that the summary is illustrative only and is not intended to be in any way 
limiting . Other aspects, inventive features, and advantages of this patent application 
will become apparent in the non-limiting detailed description set forth below. 



20 BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention may be better understood, and its numerous objects, 
features, and advantages made apparent to those skilled in the art by referencing the 
accompanying drawings. 

Fig. 1 A illustrates a pictorial representation of a conventional data processing 
25 system in which illustrative embodiments of the devices and/or processes described 
herein may be implemented. 
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Figs. IB and 1C show perspective views of portable computer system 120 and 
portable computer system 120 in the process of docking with docking station 150. 

Fig. ID illustrates a partial perspective view of undocking controls 160 of 
docking station 150. 

5 Fig. 2 depicts a representative high-level block diagram of a portion of the 

electrical components internal to both portable data processing system 120 and 
docking station 150. 

Fig. 3 shows a system similar to that shown in Figure 2, except that shown are 
additional components related to "ad hoc" tasks and/or functions associated with 
10 docking and/or undocking portable computer system 120 to/from docking station 150. 

Fig. 4 illustrates a system similar to that shown in Figure 3, except that shown 
is that a large portion of the additional components related to "ad hoc" tasks and/or 
functions associated with docking and/or undocking portable computer system 120 
to/from docking station 150 have been replaced with a scheme which utilizes a bus 
15 with well-defined characteristics. 

Fig. 5 depicts a system similar to that shown in Figure 4, wherein general 
purpose I/O controller 400 is shown controlling controllable switches 500, 502. 

Fig. 6A shows an isolated expanded view of some exemplary components 
internal to docking station 150. 

20 Fig. 6B illustrates an alternate embodiment of USB docking device class 

circuit 402 which locates general purpose I/O controller 400 internal to USB docking 
device class circuit 402. 

Fig. 7 illustrates a high-level logic flowchart of generic docking device class 
circuit 700. 

25 The use of the same reference symbols in different drawings indicates similar 

or identical items. 
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DETAILED DESCRIPTION 

As noted above, the inventors named herein have devised a method and 
system which essentially give rise to a standardized way of docking. The inventor has 
done the foregoing by devising a method and system which allow the essentially ad 
5 hoc way in which docking is currently done to be relatively easily and painlessly 
converted over to use of one of many pre-existing industry standards. In one 
implementation, this is done with what will be referred to herein as a docking device 
class circuit. 

With reference to the figures, and in particular with reference now to Figure 
10 1 A, shown is a pictorial representation of a conventional data processing system in 
which illustrative embodiments of the devices and/or processes described herein may 
be implemented. It should be noted that graphical user interface systems (e.g., 
Microsoft Windows 98 or Microsoft Windows NT operating systems) and methods 
can be utilized with the data processing system shown in Figure 1 A. Portable 
1 5 computer system 120 (a type of data processing system) is depicted which includes 
system unit housing 122, video display device 124, keyboard 126, mouse 128, and 
microphone 148. Portable computer system 120 may be implemented utilizing any 
suitable computer such as any DELL portable computer system, a product of Dell 
Computer Corporation, located in Round Rock, Texas; Dell is a trademark of Dell 
20 Computer Corporation. 

Referring now to Figures IB and 1C, respectively depicted are perspective 
views of portable computer system 120 and portable computer system 120 in the 
process of docking with docking station 150. Illustrated in Figure IB is that portable 
computer system 120 has docking connector 152 . Shown in Figure 1C is portable 

25 computer system 120 in the process of docking with docking station 150. Depicted is 
that docking station 150 has docking connector 154 which mates with docking 
connector 152 of portable computer system 120. While portable computer system 
120 can generally be implemented using any portable computer system, docking 
station 150 must generally be implemented via purchasing a proprietary docking 

30 station from the same OEM which sold/produced the portable computer system. This 
requirement for purchasing the docking station from the same OEM which 
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sold/produced the portable computer system is one problem which aspect of the 
methods and systems described herein are intended to remedy. For example, if 
portable computer system 120 is implemented via a Dell portable computer system, 
typically docking station 1 50 must be implemented via a Dell docking station. 

5 As noted above, once portable computer system 120 is docked with docking 

station 150, the hybrid system formed by portable computer system 120 docked with 
docking station 150 essentially becomes a very powerful system approaching the 
power of a stationary computer system, such as a stationary workstation. In order to 
do this, the processor and Operating System (OS) internal to portable data processing 

10 system 120 must electrically connect with the data processing system components 
internal to docking station 150 (usually through pin and socket arrangements (not 
shown) of docking connector 152 and docking connector 154, respectively) and 
thereafter become aware of the data processing system components internal to 
docking station 150. In order to become aware of data processing system components 

15 internal to or connected with docking station 150, after portable computer system 150 
is docked with docking station 150, the BIOS and/or OS internal to portable computer 
system 120 must search out and become aware of the data processing system 
components internal to or connected with docking station 150. This searching out and 
becoming aware of the data processing system components internal to or connected 

20 with docking station 150 takes a considerable amount of time, and one advantage of 
the methods and systems described herein is to decrease the time associated with the 
searching out and becoming aware of performed by the BIOS and/or OS of portable 
computer system 120. 

Once portable computer system 120 has become aware of the data processing 
25 system components within docking station 150, the hybrid system formed by portable 
computer system 120 docked with docking station 150 functions seamlessly as a 
single data processing system. For example, during operation, portable computer 
system 120 may be executing a program using RAM (random access memory) 
resident within portable computer system 120 and communicating via a NIC (network 
30 interface card) resident within docking station 150. In order to ensure that users do 
not inadvertently undock portable computer system 120 from docking station 150 
during a period of time in which portable computer system 120 and docking station 
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150 are functioning as a hybrid computer system, elaborate electrical and mechanical 
controls have been developed within the art. Mechanisms for accomplishing this 
include systems of LEDs and mechanical levers to alert the user as to when it is safe 
to undock, and servo-mechanisms which will only release portable computer system 
5 120 when the system decides it is safe to xindock. 

With reference now to Figure ID, shown is a partial perspective view of 
undocking controls 160 of docking station 150. Depicted are docking indicator LED 
131, switch/undock button 132, docking station power button 133, docking station 
power indicator LED 134, docking station hard-drive-access LED 135, eject/locking 

10 lever 138 which is shown having locked position 139, unlocked position 137, and 
eject position 136. In some embodiments, eject/locking lever 138 is manipulated 
manually, while in other embodiments servo-mechanisms under the control of 
portable computer system 120 by and through electrical connection with docking 
station 150, control eject/locking lever 138. Further shown is audio speaker 140, 

15 which in some implementations alerts the user to whether it is safe to undock portable 
computer system 120. Those skilled in the art will recognize that docking controls 
160 are merely exemplary and that many other similar implementations are known in 
the art. 

Referring now to Figure 2, depicted is a representative high-level block 
20 diagram of a portion of the electrical components internal to both portable data 
processing system 120 and docking station 150. Those skilled in the art will 
recognize that the block diagram of Figure 2 is merely exemplary, and many other 
different components may be present. 

Depicted are Liquid Crystal Display 200, Central Processing Unit(s) 202, 
25 VGA jack 204, Video Controller 206, Northbridge 208, System Memory 210, and 
Southbridge 212 interfaced and connected in a way well known to those within the 
art. Illustrated is that Southbridge 212 is interfaced with PCI (Peripheral Component 
Interconnect) bus 214, LPC (Low Pin Count) I/O bus 216, and USB (Universal Serial 
Bus) 236. (Note: Those skilled in the art will appreciate that, ordinarily, only one 
30 device is attached per USB, and that if more than one device is to be attached to a 
USB, a USB hub is used to provide for such additional devices. Accordingly, where 
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multiple devices are herein shown attached to a USB, if a USB hub is not explicitly 
shown it is to be understood that such a hub is implicitly present.) 

Shown is that PCI bus 214 has attached to it PC card controller 218 (which is 
intended to be an example of any type of PCI device attachable to PCI bus 214). 
5 Depicted is that PC Card controller 21 8 interfaces with and controls both PC Card 220 
and PC Card 222. Illustrated is that associated with PCI bus 214 is Q Switch 224 
which is either activated or deactivated in response to docking operations. 

Further shown is that LPC I/O bus 216 is interfaced with System ROM (Read 
Only Memory) 226 which in one embodiment contains the system BIOS (Basic Input 
10 Output System) firmware, System I/O Controller 228, and Keyboard Controller 230. 
Depicted is that system I/O controller 228 is connected with serial port jack 232 and 
parallel port jack 234. 

Depicted is that both PCI bus (through Q Switch 224) and USB 236 
electrically connect with docking connector 152. Illustrated is that docking connector 
15 152 mates with docking connector 1 54 such that PCI bus 2 1 4 and USB 23 6, both 

internal to portable computer system 120, are respectively electrically connected with 
PCI bus 254 and USB 276, both of which are internal to docking station 150. 
Illustrated are PCI devices 258, 258 connected with PCI bus 254. Shown are USB 
devices 278, 280 connects with USB 276. 

20 In normal operation, when portable computer system 120 is docked with 

docking station 150, PCI bus 254 (and its attached devices) and USB bus 276 (and its 
attached devices) are detected by the BIOS and/or OS of portable computer system 
120, and thereafter are used part and parcel by portable computer system 120 "as if 
such components in docking station 150 were in fact part of portable computer system 

25 120. Those skilled in the art will recognize that the foregoing described method of 
operation is generally described as "pass through." Those skilled in art will 
recognize that the processes by which the BIOS and/or the OS of portable computer 
system 120 become aware of busses and/or devices resident within docking station 
150 can become quite time consuming and complex, depending upon the way in 

30 which the busses, and their associated devices, internal to docking station 1 50 are 
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structured. The methods and systems described herein decrease the time and 
complexity associated with such operations in a manner which will be described 
below. 

As noted above, there is no standard defining docking. Those skilled in the art 
5 will appreciate that one of the main reasons why no such standard exists is that there 
is no easy way to accommodate all the various processes and devices by which OEMs 
in the related art achieve the "details" or "ad hoc" functions/tasks associated with 
docking (e.g., the functions and tasks associated with one or more of docking controls 
1 60 described in relation to Figure ID). Following is a description of a few such ad 

1 0 hoc functions/tasks (those skilled in the art will recognize that there are many more ad 
hoc functions than those described herein), and how the inventor named herein has 
defined a way to allow the OEMs to continue practicing the details in whatever 
fashion they choose, while allowing such free-form ad hoc functions to be detected 
and controlled in a standardized way which will translate across systems and 

1 5 platforms. 

With reference now to Figure 3, shown is a system similar to that shown in 
Figure 2, except that shown are additional components related to "ad hoc" 
tasks/functions associated with docking and/or undocking portable computer system 
120 to/from docking station 150. Depicted is that docking station 150 now has 

20 resident within it sideband signal controller 300 (those skilled in the art will recognize 
that ad hoc functions associated with docking are generally referred to as "sideband" 
functions/tasks, since such functions/tasks are outside of any defined recognized 
standard), which controls audio speaker 140, docking station hard-drive-access LED 
135, and switch/undock button 132. Illustrated is that docking connector 152 mated 

25 with docking connector 154 provides electrical connection between sideband signal 
controller 300 and its counterpart, sideband signal controller 302, resident within 
portable computer system 120. 

Shown is that sideband signal controller 302 is under the control of keyboard 
controller 230 - however, those skilled in the art will recognize other implementations 
30 are possible: there is no defined standard way to accommodate ad hoc docking station 
functions/tasks. Depicted is that sideband signal controller 302 is in communication 
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with system ROM 226, from which sideband signal controller 302 retrieves ASL 
(ACPI Source Language) code. 

Those skilled in the art will recognize that, since there is currently no 
standardized way to account for devices, related to ad hoc functions/tasks, that may be 
5 present in docking station 1 50, it is generally necessary in the art to actually know 
beforehand what devices will most likely be present in docking station 150, and hence 
hard-code the commands for such known-beforehand devices into system ROM 226. 
Thereafter, when sideband signal controller 302 needs to issue a command to a device 
through sideband signal controller 300, sideband controller 302 retrieves the ASL 

1 0 code from the system BIOS in system ROM 226 and uses such ASL code to 

communicate with the device to which commands are to be issued. (Note: those 
skilled in the art will appreciate that in actual operation, the sideband controller 
actually works with the OS which (1) fetches the ASL code from BIOS, (2) interprets 
the ASL code, (3) creates commands and routines in response to the interpretation of 

1 5 the ASL code, and (4) supplies the sideband controller with the created commands 
and routines; however, for sake of ease of understanding, the foregoing sequence is 
referred to herein as the sideband controller retrieving the ASL code.) 

Those skilled in art will recognize that the necessity to hard-code the ASL 
code into the system BIOS is a tremendous disadvantage, and tends to make docking 

20 stations relatively inflexible. It certainly makes it virtually impossible to provide 
open-systems docking across multiple OEMs, and even makes it difficult to provide 
cross-system compatibility between various systems made by the same OEM. 
However, OEMs have become attached to the flexibility, power, and competitive 
advantage attached to the ad hoc way of docking. Consequently, it is apparent that if 

25 open-systems docking is ever to be achieved, such must be accomplished via methods 
and systems which preserve the flexibility, power, and competitive advantage 
attached to the ad hoc way of docking. Methods and systems which accomplish the 
foregoing will now be described. 

Referring now to Figure 4, depicted is a system similar to that shown in Figure 
30 3, except that shown is that a large portion of the additional components related to "ad 
hoc" tasks and/or functions associated with docking and/or undocking portable 
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computer system 120 to/from docking station 150 have been replaced with a scheme 
which utilizes a bus with well-defined characteristics (e.g., a USB in the scheme 
shown in Figure 4, but those skilled in the art will recognize that other well-defined 
bus types can be used). Shown in Figure 4 is that, while audio speaker 140, docking 
station hard-drive-access LED 135, and switch/undock button 132 as described in 
Figure 3 are still present, sideband controllers 300, 302, and a majority of the ASL 
code describing devices related to ad hoc functions/tasks related to docking are no 
longer present (e.g., in one implementation, a minimal subset of ASL code which 
describes USB docking device class circuit 402 is present in the BIOS). Instead, 
shown is that audio speaker 140, docking station hard-drive-access LED 135, and 
switch/undock button 132 are now interfaced with and controlled by general purpose 
I/O controller 400. General purpose I/O controller 400 is intended to be indicative of 
devices control and/or interact with input devices, or output devices, or both input 
devices and output devices. 

Depicted is that general purpose I/O controller 400 is interfaced with and 
controlled by USB Docking Device Class Circuit 402. Illustrated is that USB 
Docking Device Class Circuit 402 is attached to USB 276. 

In operation, during system initialization, the BIOS and/or OS of portable 
computer system 120 detects the presence of USB docking device class circuit 402. 
In one implementation, the detection of USB docking device class circuit 402 is done 
via the detection of a USB identification number specifically associated with USB 
docking device class circuit 402; in one implementation the foregoing is established 
via an unassigned USB identifier, but it is expected by the inventor named herein that 
at some point in the future by either the USB Irnplementers Forum, Inc. (a non-profit 
corporation founded by the group of companies that developed the USB specification, 
with a physical presence in Portland, Oregon, and a Web presence at the following 
URL: http://www.usb.org/info.html ) or the docking station industry generally will 
actually define a specific USB identification number specifically associated with USB 
Docking Device Class Circuit 402. 

Once the BIOS and/or OS of portable computer system 120 detects the 
presence of USB docking device class circuit 402, the BIOS and/or OS of portable 
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computer system 120 queries USB docking device class circuit 402 as to the devices 
necessary to the ad hoc functions/tasks associated with docking. In response, the 
BIOS and/or OS of portable computer system 120 detects the presence of USB 
docking device class circuit 402, and provides the BIOS and/or OS with the ACPI 
tables necessary to define interaction with such devices. (For background information 
related to ACPI related to docking, one good reference manual is Microsoft 
Corporation's ACPI Docking for Windows 2000, DRAFT VERSION 0.7 (December 
21, 1998), hereby incorporated by reference in its entirety; and USB Specifications 
1.1 and 2.0, available from the USB Implemented Forum of Portland, Oregon and/or 
the following link: htt p://www.usb.org) , hereby incorporated by reference in their 
entireties. In addition to the foregoing, both Microsoft Corporation and Intel 
Corporation both maintain web sites which provide very substantial background 
material related to ACPI, USB, docking, and other background issues which may 
prove useful to those skilled in the art. It is to be under stood that any and all of the 
references referred to or cited herein are hereby incorporated by reference in their 
entireties.) Thereafter, the BIOS and/or OS of portable computer system 120 retrieves 
the driver code for the detected devices; in one implementation, such retrieval is from 
disk storage on-board portable computer system 120 , while in another 
implementation, such retrieval is done from a storage device (e.g., a hard disk drive) 
within docking station 150. 

Once the BIOS and/or OS of portable computer system 120 has become aware 
of and has been supplied the appropriate ACPI tables defining ad hoc devices such as 
audio speaker 140, docking station hard-drive-access LED 135, and switch/undock 
button 132, portable computer system 120 can then, by and through USB docking 
device class circuit 402, control such ad hoc devices through standard programming 
commands associated with USB devices. Accordingly, the scheme shown and 
described in relation to Figure 4 allows standardized control and recognition of 
devices associated with ad hoc functions/tasks associated with docking operations, 
without limiting the freedom of OEMs to use virtually any approach whatsoever with 
respect to the ad hoc functions and tasks employed or the devices used to effect same. 
That is, OEMs can attach virtually any device they so desire to general purpose I/O 
controller 400. 
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Those skilled in the art will recognize that in addition or in the alternative to 
the problems associated with detecting and controlling devices associated with ad hoc 
functions/tasks related to docking, other problems, related to power supplies, arise in 
the context of docking. Specifically, some portable computer system OEMs utilize 12 
5 volt power supplies, while others utilize 18 volt power supplies, while still others 
utilize 24 volt power supplies. Since it is common and substantially preferable in the 
art to provide power to portable computer system 120 by and through docking station 
1 50 (e.g., via use of docking station power button 133), in order to provide true open- 
systems docking, it is desirable to allow the same docking station to provide power to 
10 a variety of portable computer systems employing a variety of power schemes. USB 
Docking Device Class Circuit 402 provides such capability. 

With reference now to Figure 5, depicted is a system similar to that shown in 
Figure 4, wherein general purpose I/O controller 400 is shown controlling controllable 
switches 500 and 502. Controllable switches 500 and 502 control which of 18 volt 

15 power supply 504 or 12 volt power supply 506 respectively drive docking-station-to- 
portable-computer system power rail 508. (Those skilled in the art will appreciate 
that controllable switches 500, 502, and 18 volt power supply 504, and 12 volt power 
supply 506 are exemplary only and that other switching devices (e.g., muxes) and 
power supplies (e.g., a 24 volt supply) can be utilized under the spirit of the teaching 

20 herein.) 

The BIOS and/or OS of portable computer system 120 becomes aware of 
controllable switches 500, 502, and 18 volt power supply 504, and 12 volt power 
supply 506 through USB docking device class circuit 402 via a process analogous to 
that described previously (e.g., the BIOS and/or OS becoming aware of USB docking 

25 device class circuit 402, and thereafter obtaining information of the devices under the 
control of USB docking device class circuit 402 (which in one implementation 
controls such devices through general purpose I/O controller 400)). After BIOS 
and/or OS of portable computer system 120 determines the power supplies available, 
portable computer system 120 can issue commands, through USB docking device 

30 class circuit 402, to ensure that the power supply driving docking-station-to-portable- 
computer system power rail 508 ~ which is shown electrically connected with 
portable-computer-system power rail 510 through docking connector 152 coupled 
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with docking connector 154 -- is the power supply appropriate to portable computer 
system 120. Thus, docking device class circuit 402 can provide docking stations with 
the ability to interface with portable computer systems having different power supply 
requirements. 

It was mentioned above that determining the bus structure internal to docking 
station 150 can be time consuming and complex. In one implementation, USB 
Docking Device Class Circuit 400 decreases such time and complexity. 

Referring now to Figure 6A, shown is an isolated expanded view of some 
exemplary components internal to docking station 150. Shown is that in one 
implementation, in addition or in the alternative to the functions of USB Docking 
Device Class Circuit 402 described in relation to Figures 4 and 5, USB Docking 
Device Class Circuit 402 is further shown having bus description table 600. Bus 
description table 600 is shown having PCI bus description 602, USB description 604, 
AGP bus description 606, and GPI/OC (General Purpose I/O Controller 402) bus 
description 607. PCI bus description 602, USB description 604, AGP bus description 
606, and GPI/OC bus description 607 describe the devices attached to their 
respectively identified busses. Accordingly, BIOS and/or OS of portable computer 
system 120 can obtain information about the internal structure of docking station 150 
without going through the lengthy discovery process existing in the related art. In one 
implementation, the docking device administrator programs bus description table 600 
with information representative of the bus structure of docking device 150, while in 
another implementation, docking device class circuit 402 polls and logs the 
configuration of the bus structure of docking device 150 in a fashion analogous to the 
way in which portable computer system 120 determines such information in the 
related art. 

Insofar as USB Docking Device Class Circuit 402 is now performing 
additional functions beyond those described in Figures 4 and 5, depicted is that USB 
Docking Device Class Circuit 402 now has internal to it function router 608, which 
appropriately routes messages to either general purpose I/O controller 400 or bus 
description table 600. Lastly, shown is that interposed between USB Docking Device 
Class Circuit 402 and USB 276 is USB hub logic 610, which is used to show one of 
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the more powerful implementations of a system utilizing some of the advantages of 
USB Docking Device Class Circuit 402. Depicted attached to USB hub logic 610 are 
USB port 612 and NIC Logic 614. Illustrated attached to NIC Logic 614 is RJ 45 
connector 616. 

Also shown is that USB hub logic 610 has USB hub description table 61 1, 
which allows USB docking device class circuit 402 to be identified as an "internal" 
port USB device. This is an indication that the port associated with the USB docking 
device class circuit 402 is not an external port providing pluggable access to the user. 
This implementation allows the OS to be more efficient in managing USB docking 
device class circuit 402. 

Further shown in Figure 6A is that PCI bus 254 is now enumerated as PCIobus 
254, which is bridged to PCL bus 61 8 through PCI bridge 620. Depicted attached to 
PCIi bus 618 are SCSI (Small Computer System Interface) 622, audio card 624, and 
video card 626. Those skilled in the art will recognize that detecting and 
enumerating bridged busses - and their attached devices - internal to docking station 
150 (e.g., similar to PCI 0 bus 254 bridged to PCIi bus 618) is a very vexing problem in 
the related art. However, the presence of bus description table 600 within the 
confines of USB Docking Device Class Circuit 402 allow such information to be 
garnered in a quick and efficient fashion without engaging in the time consuming and 
complex processes necessary to detect and enumerate such busses under the related 
art. As an additional point, enhancements to controlling the PCI bus can be gained by 
the use of bus description table 600. As an example, the compatibility bus (e.g., PCIo) 
could be swapped with PCIi should the designer desire to swap the compatibility bus 
between docking station 150 and portable computer system 120. 

Referring now to Figure 6B, shown is an alternate embodiment of USB 
docking device class circuit 402 which locates general purpose I/O controller 400 
internal to USB docking device class circuit 402. In general, such an alternate 
embodiment can also be applied to substantially any embodiment of USB docking 
device class circuit 402 described herein (e.g., the embodiments described in relation 
to Figures 4 and 5). 
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With reference now to Figure 7, shown is a high level logic flowchart of 
generic docking device class circuit 700. Generic docking device class circuit 700 is 
intended to illustrate that USB docking device class circuit 402-is illustrative of a 
more general type of docking device class circuit which can be attached to buses other 
5 than USB. As illustrated in Figure 7, docking device class circuit 700 is a device: (1) 
which will interface and function with a bus for which well known standards (either 
de facto or de jure) are defined (e.g., USB, PCI, AT, etc.), and (2) which contains 
within it information which defines at least one subset of the "universe" of the 
docking station of which it (the docking device class circuit) forms a part, and (3) 

10 which will thereby allow identification and/or control of one or more data processing 
system components which make up the at least one subset of the universe of the 
docking station via use of well known and well defined functions associated with the 
bus with which the docking device class circuit is interfaced. The "universe" of the 
docking station can include but is not limited to ad hoc hardware and software within 

15 the docking station (e.g., docking-station hard-drive access LED 135, and 

switch/undock button 132), the bus structures and associated devices in the docking 
station, and/or the power supply types and/or voltages within the docking station. 
Illustrated is that generic docking device class circuit 700 interfaces with docking 
connector 154 through a bus of known type 702. 

20 Referring now to Figure 8, shown is a high-level logic flowchart. Method step 

800 shows the start of the process. Method step 802 depicts the step of detecting a 
docking device class circuit present on a bus; in one implementation, the step (method 
step 802) of detecting a docking device class circuit present on a bus includes but is 
not limited to the sub-step of detecting an identification number reserved for the 

25 docking device class circuit (e.g., detecting a USB identification number as described 
herein). Method step 804 illustrates the step of obtaining a description of at least one 
device in a docking station from the docking device class circuit. Method step 806 
shows the (optional) step of controlling the at least one device via commands 
appropriate to the bus. (Method step 806 is shown as an optional step because in one 

30 embodiment the information obtained is that of bus structure internal to a docking 

device, and thus the commands issued can be on a bus other than the bus to which the 
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docking class device circuit is attached.) Method step 808 depicts the end of the 
process. 

With reference now to Figure 9, shown is that in one implementation, the step 
(method step 804) of obtaining a description of at least one device in a docking station 
5 from the docking device class circuit includes but is not limited to the sub-step 
(method step 900) of obtaining a list of devices under the control of the docking 
device class circuit. Depicted is that in one implementation, the sub-step (method 
step 900) of obtaining a list of devices under the control of the docking device class 
circuit includes but is not limited to the sub-step (method step 902) of obtaining a list 

10 of devices under the control of a general purpose I/O device under the control of the 
docking device class circuit. Illustrated is that in one implementation, the sub-step 
(method step 900) of obtaining a list of devices under the control of the docking 
device class circuit includes but is not limited to the sub-step (method step 904) of an 
OS of a portable computer system obtaining driver code appropriate to the at least one 

1 5 device (or, alternatively, the driver code appropriate to the device class docking 
circuit can be obtained); in one implementation, the driver code is obtained from 
storage on-board the portable computer system, while in another implementation, the 
driver code is obtained from or through the device class docking circuit (e.g., driver 
code for the device class docking circuit can be obtained from the device class 

20 docking circuit, driver code for devices can be obtained from the device class docking 
circuit, or driver code for the devices can be obtained from the devices themselves 
through the device class docking circuit). 

With reference now to Figure 10, shown is that in one embodiment, the step 
(method step 804) of obtaining a description of at least one device in a docking station 

25 from the docking device class circuit includes but is not limited to the sub-step 

(method step 1000) of obtaining a bus description table from the docking device class 
circuit. Depicted is that in one embodiment, the sub-step (method step 1000) of 
obtaining a bus description table from the docking device class circuit includes but is 
not limited to the sub-step (method step 1002) of obtaining a description of at least 

30 one Peripheral Component Interconnect bus resident within a docking device, or at 
least one Universal Serial Bus resident within a docking device, or at least one 
Accelerated Graphics Port Bus resident within a docking device, or at least one AT 
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bus resident within a docking device, or at least one proprietary bus resident within a 
docking device, or at least one wireless bus resident within a docking device, or at 
least one optical bus resident within a docking device. 

With reference now to Figure 11, depicted is that with respect to the (optional) 
5 step (method step 806) of controlling the at least one device via commands 

appropriate to the bus, in one implementation the bus to which the docking class 
device circuit is attached is a Universal Serial Bus; in one embodiment the bus to 
which the docking class device circuit is attached is a Peripheral Component 
Interconnect bus, and in one embodiment the bus to which the docking class device 

10 circuit is attached is an AT bus. Illustrated is that, in one implementation, the step 
(method step 806) of controlling the at least one device via commands appropriate to 
the bus includes but is not limited to the sub-step (method step 1 102) of controlling at 
least one device associated with docking. Shown is that, in one implementation, the 
sub-step (method step 1 102) of controlling the at least one device via commands 

15 appropriate to the bus includes but is not limited to the sub-step (1 104) of controlling 
at least one power supply in a docking station. Depicted is that, in one 
implementation, the sub-step (method step 1104) of controlling at least one power 
supply in a docking station includes but is not limited to the sub-step (method step 
1 106) of activating a power supply having voltage appropriate to a portable computer 

20 system. 

Those skilled in the art will recognize that the state of the art has progressed to 
the point where there is little distinction left between hardware and software 
implementations of aspects of systems; the use of hardware or software is generally 
(but not always, in that in certain contexts the choice between hardware and software 

25 can become significant) a design choice representing cost vs. efficiency tradeoffs. 
The foregoing detailed description has set forth various embodiments of the devices 
and/or processes via the use of block diagrams, flowcharts, and examples. Insofar as 
such block diagrams, flowcharts, and examples contain one or more functions and/or 
operations, it will be understood as notorious by those within the art that each 

30 function and/or operation within such block diagrams, flowcharts, or examples can be 
implemented, individually and/or collectively, by a wide range of hardware, software, 
firmware, or any combination thereof. In one embodiment, the devices and/or 
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processes described herein may be implemented via Application Specific Integrated 
Circuits (ASICs). However, those skilled in the art will recognize that the 
embodiments disclosed herein, in whole or in part, can be equivalently implemented 
in standard Integrated Circuits, as a computer program running on a computer, as 
5 firmware, or as virtually any combination thereof and that designing the circuitry 

and/or writing the code for the software or firmware would be well within the skill of 
one of ordinary skill in the art in light of this disclosure. In addition, those skilled in 
the art will appreciate that the mechanisms of the devices and/or processes described 
herein are capable of being distributed as a program product in a variety of forms, and 

10 that an illustrative embodiment of the devices and/or processes described herein 
applies equally regardless of the particular type of signal bearing media used to 
actually carry out the distribution. Examples of a signal bearing media include but are 
not limited to the following: recordable type media such as floppy disks, hard disk 
drives, CD ROMs, digital tape, and transmission type media such as digital and 

15 analogue communication links using TDM or IP based communication links (e.g., 
packet links). 

In a general sense, those skilled in the art will recognize that the various 
embodiments described herein which can be implemented, individually and/or 
collectively, by a wide range of hardware, software, firmware, or any combination 

20 thereof can be viewed as being composed of various types of "electrical circuitry." 
Consequently, as used herein "electrical circuitry" includes but is not limited to 
electrical circuitry having at least one discrete electrical circuit, electrical circuitry 
having at least one integrated circuit, electrical circuitry having at least one 
application specific integrated circuit, electrical circuitry forming a general purpose 

25 computing device configurable by a computer program (e.g., a general purpose 

computer configurable by a computer program or a microprocessor configurable by a 
computer program), electrical circuitry forming a memory device (e.g., any and all 
forms of random access memory), and electrical circuitry forming a communications 
device (e.g., a modem, communications switch, or optical-electrical equipment). 

30 Those skilled in the art will recognize that it is common within the art to 

describe devices and/or processes in the fashion set forth above, and thereafter use 
standard engineering practices to integrate such described devices and/or processes 
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into data processing systems. That is, the devices and/or processes described above 
can be integrated into data processing system via a reasonable amount of 
experimentation. Figures 1 A- ID show an example representation of a data processing 
system into which the described devices and/or processes may be implemented with a 
5 reasonable amount of experimentation. 

Those skilled in the art will appreciate that the hardware depicted in Figures 
1A-1D may vary for specific applications. For example, other peripheral devices such 
as optical disk media, audio adapters, video cameras such as those used in 
videoconferencing, or programmable devices, such as PAL or EPROM programming 
10 devices well-known in the art of computer hardware, and the like may be utilized in 
addition to or in place of the hardware already depicted. 

Those skilled in the art will recognize that portable computer system 120 can 
be described in relation to data processing systems which perform essentially the 
same functions, irrespective of architectures. Consequently, as used herein specific 
1 5 exemplars of data processing systems and data processing system components are 
intended to be representative of their more general types. 

Those skilled in the art will recognize that data processing system 120 can be 
described in relation to data processing systems which perform essentially the same 
functions, irrespective of architectures. 

20 Although many components are shown herein as electrically connected, it is to 

be understood that alternate embodiments of such connections are contemplated 
which can be either wireless or optical connections via the addition of a relatively 
minor amount of circuitry which can be achieved, without undue experimentation, by 
those having ordinary skill in the art. As a more specific example, substantially any 

25 bus described herein could be replaced by an optical or wireless bus. 

Although the examples used herein have shown docking accomplished via use 
of LPC bus 216, those skilled in the art will recognize that the use of such bus is 
merely exemplary, and that other implementations fall within the spirit of the teaching 
herein. For example, docking can be done through a PCI bus, or directly though a 
30 Southbridge, or via use of a proprietary bus, etc. 
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Other embodiments are within the following claims. 

The foregoing described embodiments depict different components contained 
within, or connected with, different other components. It is to be understood that such 
depicted architectures are merely exemplary, and that in fact many other architectures 
5 can be implemented which achieve the same functionality. In a conceptual sense, any 
arrangement of components to achieve the same functionality is effectively 
"associated" such that the desired functionality is achieved. Hence, any two 
components herein combined to achieve a particular functionality can be seen as 
"associated with" each other such that the desired functionality is achieved, 
10 irrespective of architectures or intermedial components. Likewise, any two 

components so associated can also be viewed as being "operably connected", or 
"operably coupled", to each other to achieve the desired functionality. 

While particular embodiments of the devices and/or processes described 
herein have been shown and described, it will be obvious to those skilled in the art 

1 5 that, based upon the teachings herein, changes and modifications may be made 
without departing from this invention and its broader aspects and, therefore, the 
appended claims are to encompass within their scope all such changes and 
modifications as are within the true spirit and scope of this invention. Furthermore, it 
is to be understood that the invention is solely defined by the appended claims. It will 

20 be understood by those within the art that if a specific number of an introduced claim 
element is intended, such an intent will be explicitly recited in the claim, and in the 
absence of such recitation no such intent is present. For example, as an aid to 
understanding, the following appended claims may contain usage of the introductory 
phrases "at least one" and "one or more" to introduce claim elements. However, the 

25 use of such phrases should not be construed to imply that the introduction of a claim 
element by the indefinite articles "a" or "an" limits any particular claim containing 
such introduced claim element to inventions containing only one such element, even 
when the same claim includes the introductory phrases "one or more" or "at least one" 
and indefinite articles such as "a" or "an"; the same holds true for the use of definite 

30 articles used to introduce claim elements. In addition, even if a specific number of an 
introduced claim element is explicitly recited, those skilled in the art will recognize 
that such recitation should typically be interpreted to mean at least the recited number 
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WHAT IS CLAIMED IS: 

1 1 . A method comprising: 

2 detecting a docking device class circuit present on a bus; and 

3 obtaining a description of at least one device in a docking station from the 

4 docking device class circuit. 

1 2. The method of Claim 1, further comprising: 

2 controlling the at least one device via commands appropriate to the bus. 

1 3. The method of Claim 2, wherein the bus comprises at least one 

2 Universal Serial Bus, at least one Peripheral Component Interconnect Bus, or at least 

3 one AT bus, or at least one wireless bus, or at least one optical bus. 

1 4. The method of Claim 2, wherein said controlling the at least one 

2 device via commands appropriate to the bus further comprises: 

3 controlling at least one device associated with docking. 

1 5. The method of Claim 2, wherein said controlling the at least one 

2 device via commands appropriate to the bus further comprises: 

3 controlling at least one power supply in a docking station. 

1 6. The method of Claim 5, wherein said controlling at least one power 

2 supply in a docking station further comprises: 

3 activating a power supply having voltage appropriate to a portable computer 

4 system. 

1 7. The method of Claim 2, wherein said controlling the at least one 

2 device via commands appropriate to the bus further comprises: 

3 controlling at least one power rail that supplies power to a portable computer 

4 system. 

1 8. The method of Claim 1, wherein said detecting a docking device class 

2 circuit present on a bus further comprises: 

3 detecting an identifier associated with the docking device class circuit. 
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1 9. The method of Claim 8, wherein said detecting an identifier associated 

2 with the docking device class circuit further comprises: 

3 detecting an identification number reserved for the docking device class 

4 circuit. 

1 10. The method of Claim 1 , wherein said obtaining a description of at least 

2 one device in a docking station from the docking device class circuit further 

3 comprises: 

4 obtaining a list of devices under the control of the docking device class circuit. 

1 11. The method of Claim 10, wherein said obtaining a list of devices under 

2 the control of the docking device class circuit further comprises: 

3 obtaining a list of devices under the control of a general purpose I/O device 

4 under the control of the docking device class circuit. 

1 12. The method of Claim 10, wherein said obtaining a list of devices under 

2 the control of the docking device class circuit further comprises: 

3 obtaining driver code appropriate to the at least one device. 

1 13. The method of Claim 10, wherein said obtaining a list of devices under 

2 the control of the docking device class circuit further comprises: 

3 obtaining driver code appropriate to the docking device class circuit. 

1 14. The method of Claim 10, wherein said obtaining a list of devices under 

2 the control of the docking device class circuit further comprises: 

3 obtaining driver code combination set appropriate to both the docking device 

4 class circuit and the at least one device. 

1 15. The method of Claim 1, wherein said obtaining a description of at least 

2 one device in a docking station from the docking device class circuit further 

3 comprises: 

4 obtaining a bus description table from the docking device class circuit. 

1 16. The method of Claim 15, wherein said obtaining a bus description 

2 table from the docking device class circuit further comprises: 
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3 obtaining a description of at least one Peripheral Component Interconnect bus 

4 resident within a docking device, or at least one Universal Serial Bus 

5 resident within a docking device, or at least one Accelerated Graphics 

6 Port Bus resident within a docking device, or at least one AT bus 

7 resident within a docking device, or at least one proprietary bus, or at 

8 least on wireless bus, or at least one optical bus. 

1 17. A docking station comprising: 

2 a docking device class circuit. 

1 18. The docking station of Claim 17, further comprising: 

2 the docking device class circuit operably coupled to a device associated with 

3 docking. 

1 19. The docking station of Claim 1 8, further comprising: 

2 the docking device class circuit operably coupled to at least one device 

3 associated with ad hoc functions or at least one power supply device. 

1 20. The docking station of Claim 17, further comprising: 

2 the docking device class circuit operably coupled to a general purpose I/O 

3 controller. 

1 21 . The docking station of Claim 17, said docking device class circuit 

2 further comprising: 

3 the docking device class circuit having a bus description table. 

1 22. The docking station of Claim 17, further comprising: 

2 at least one optical connector or at least one wireless connector. 

1 23. A data processing system comprising: 

2 circuitry for detecting a docking device class circuit present on a bus, wherein 

3 said circuitry for detecting includes one or more electrical circuits 

4 selected from the group including but not limited to electrical circuits 

5 having at least one discrete electrical circuit, electrical circuits having 

6 at least one integrated circuit, electrical circuits having at least one 
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7 application specific integrated circuit, and electrical circuits providing 

8 a general purpose computing device configurable by a computer 

9 program; 

10 circuitry for obtaining a description of at least one device in a docking station 

1 1 from the docking device class circuit, wherein said circuitry for 

12 obtaining includes one or more electrical circuits selected from the 

1 3 group including but not limited to electrical circuits having at least one 

14 discrete electrical circuit, electrical circuits having at least one 

1 5 integrated circuit, electrical circuits having at least one application 

1 6 specific integrated circuit, and electrical circuits providing a general 

17 purpose computing device configurable by a computer program; and 

18 at least one of said circuitry for detecting, and said circuitry for obtaining 

1 9 operably coupled, either directly or through one or more intermedial 

20 circuits, to at least one data processing system component selected 

21 from the group including a processor device, a display device, a 

22 memory device, and a communication device. 

1 24. The data processing system of Claim 23, further comprising: 

2 circuitry for controlling the at least one device via commands appropriate to 

3 the bus, wherein said circuitry for controlling includes one or more 

4 electrical circuits selected from the group including but not limited to 

5 electrical circuits having at least one discrete electrical circuit, 

6 electrical circuits having at least one integrated circuit, electrical 

7 circuits having at least one application specific integrated circuit, and 

8 electrical circuits providing a general purpose computing device 

9 configurable by a computer program. 

1 25. The data processing system of Claim 24, wherein the bus comprises at 

2 least one Universal Serial Bus, at least one Peripheral Component Interconnect Bus, 

3 or at least one AT bus, or at least one wireless bus, or at least one optical bus. 

1 26. The data processing system of Claim 24, wherein said circuitry for 

2 controlling the at least one device via commands appropriate to the bus further 

3 comprises: 
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4 circuitry for controlling at least one device associated with docking. 

1 27. The data processing system of Claim 24, wherein said circuitry for 

2 controlling the at least one device via commands appropriate to the bus further 

3 comprises: 

4 circuitry for controlling at least one power supply in a docking station. 

1 28. The data processing system of Claim 27, wherein said circuitry for 

2 controlling at least one power supply in a docking station further comprises: 

3 circuitry for activating a power supply having voltage appropriate to a portable 

4 computer system. 

1 29. The data processing system of Claim 24, wherein said circuitry for 

2 controlling the at least one device via commands appropriate to the bus further 

3 comprises: 

4 circuitry for controlling at least one power rail that supplies power to a 

5 portable computer system. 

1 30. The data processing system of Claim 23, wherein said circuitry for 

2 detecting a docking device class circuit present on a bus further comprises: 

3 circuitry for detecting an identifier associated with the docking device class 

4 circuit. 

1 31. The data processing system of Claim 30, wherein said circuitry for 

2 detecting an identifier associated with the docking device class circuit further 

3 comprises: 

4 circuitry for detecting an identification number reserved for the docking 

5 device class circuit. 

1 32. The data processing system of Claim 23, wherein said circuitry for 

2 obtaining a description of at least one device in a docking station from the docking 

3 device class circuit further comprises: 

4 circuitry for obtaining a list of devices under the control of the docking device 

5 class circuit. 
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1 33. The data processing system of Claim 32, wherein said circuitry for 

2 obtaining a list of devices under the control of the docking device class circuit further 

3 comprises: 

4 circuitry for obtaining a list of devices under the control of a general purpose 

5 I/O device under the control of the docking device class circuit. 

1 34. The data processing system of Claim 32, wherein said circuitry for 

2 obtaining a list of devices under the control of the docking device class circuit further 

3 comprises: 

4 circuitry for obtaining driver code appropriate to the at least one device. 

1 35. The data processing system of Claim 32, wherein said circuitry for 

2 obtaining a list of devices under the control of the docking device class circuit further 

3 comprises: 

4 circuitry obtaining driver code appropriate to the docking device class circuit. 

1 36. The data processing system of Claim 32, wherein said circuitry for 

2 obtaining a list of devices under the control of the docking device class circuit further 

3 comprises: 

4 circuitry for obtaining driver code combination set appropriate to both the 

5 docking device class circuit and the at least one device. 

1 37. The data processing system of Claim 23, wherein said circuitry for 

2 obtaining a description of at least one device in a docking station from the docking 

3 device class circuit further comprises: 

4 circuitry for obtaining a bus description table from the docking device class 

5 circuit. 

1 38. The data processing system of Claim 37, wherein circuitry for 

2 obtaining a bus description table from the docking device class circuit further 

3 comprises: 

4 circuitry for obtaining a description of at least one Peripheral Component 

5 Interconnect bus resident within a docking device, or at least one 
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6 Universal Serial Bus resident within a docking device, or at least one 

7 Accelerated Graphics Port Bus resident within a docking device, or at 

8 least one AT bus resident within a docking device, or at least one 

9 proprietary bus, or at least on wireless bus, or at least one optical bus. 

1 39. A program product comprising: 

2 program code for detecting a docking device class circuit present on a bus; and 

3 program code for obtaining a description of at least one device in a docking 

4 station from the docking device class circuit; and 

5 signal bearing media bearing said means for detecting and said means for 

6 obtaining. 

1 40. The program product of Claim 39, wherein said signal bearing media 

2 further comprises recordable media or transmission media. 

1 41 . The program product of Claim 39, further comprising: 

2 said signal bearing media further bearing program code for controlling the at 

3 least one device via commands appropriate to the bus. 

1 42. The program product of Claim 41, wherein the bus comprises at least 

2 one Universal Serial Bus, at least one Peripheral Component Interconnect Bus, or at 

3 least one AT bus, or at least one wireless bus, or at least one optical bus. 

1 43. The program product of Claim 41, wherein said program code for 

2 controlling the at least one device via commands appropriate to the bus further 

3 comprises: 

4 program code for controlling at least one device associated with docking. 

1 44. The program product of Claim 41, wherein said program code for 

2 controlling the at least one device via commands appropriate to the bus further 

3 comprises*. 

4 program code for controlling at least one power supply in a docking station. 

1 45. The program product of Claim 44, wherein said program code for 

2 controlling at least one power supply in a docking station further comprises: 
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3 program code for activating a power supply having voltage appropriate to a 

4 portable computer system. 

1 46. The program product of Claim 41, wherein said program code for 

2 controlling the at least one device via commands appropriate to the bus further 

3 comprises: 

4 program code for controlling at least one power rail that supplies power to a 

5 portable computer system. 

1 47. The program product of Claim 39, wherein said program code for 

2 detecting a docking device class circuit present on a bus further comprises: 

3 program code for detecting an identifier associated with the docking device 

4 class circuit. 

1 48. The program product of Claim 47, wherein said program code for 

2 detecting an identifier associated with the docking device class circuit further 

3 comprises: 

4 program code for detecting an identification number reserved for the docking 

5 device class circuit. 

1 49. The program product of Claim 39, wherein said program code for 

2 obtaining a description of at least one device in a docking station from the docking 

3 device class circuit further comprises: 

4 program code for obtaining a list of devices under the control of the docking 

5 device class circuit. 

1 50. The program product of Claim 49, wherein said program code for 

2 obtaining a list of devices under the control of the docking device class circuit further 

3 comprises: 

4 program code for obtaining a list of devices under the control of a general 

5 purpose I/O device under the control of the docking device class 

6 circuit. 

1 51. The program product of Claim 49, wherein said program code for 
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2 obtaining a list of devices under the control of the docking device class circuit further 

3 comprises: 

4 program code for obtaining driver code appropriate to the at least one device. 

1 52. The program product of Claim 49, wherein said program code for 

2 obtaining a list of devices under the control of the docking device class circuit further 

3 comprises: 

4 program code for obtaining driver code appropriate to the docking device class 

5 circuit. 

1 53. The program product of Claim 49, wherein said program code for 

2 obtaining a list of devices under the control of the docking device class circuit further 

3 comprises: 

4 program code for obtaining driver code combination set appropriate to both 

5 the docking device class circuit and the at least one device. 

1 54. The program product of Claim 39, wherein said program code for 

2 obtaining a description of at least one device in a docking station from the docking 

3 device class circuit further comprises: 

4 program code for obtaining a bus description table from the docking device 

5 class circuit. 

1 55. The program product of Claim 54, wherein said program code for 

2 obtaining a bus description table from the docking device class circuit further 

3 comprises: 

4 program product for obtaining a description of at least one Peripheral 

5 Component Interconnect bus resident within a docking device, or at 

6 least one Universal Serial Bus resident within a docking device, or at 

7 least one Accelerated Graphics Port Bus resident within a docking 

8 device, or at least one AT bus resident within a docking device, or at 

9 least one proprietary bus, or at least on wireless bus, or at least one 
10 optical bus. 
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DOCKING DEVICE CLASS SYSTEM AND METHOD 

La Vaughn F. Watts, Jr. 

ABSTRACT OF THE DISCLOSURE 

A method including but not limited to detecting a docking device class circuit 
5 present on a bus, and obtaining a description of at least one device in a docking 

station from the docking device class circuit. In one embodiment the method further 
includes but is not limited to controlling the at least one device via commands 
appropriate to the bus. In one embodiment, circuitry is utilized to effect the 
foregoing-described method. In addition, a related docking station having a docking 
10 device class circuit is described. 
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detect a docking device class circuit present on a bus; in one implementation, detecting a docking 
device class circuit present on a bus includes but is not limited to detecting an identification number 
reserved for the docking device class circuit (e.g., detecting a USB identification number) 



obtain a description of at least one device in a docking 
station from the docking device class circuit 



control the at least 
one device via 
commands 
appropriate to the 
bus 




detect a docking device class circuit present on a bus; in one implementation, detecting a docking 
device class circuit present on a bus includes but is not limited to detecting an identification number 
reserved for the docking device class circuit (e.g., detecting a USB identification number) 




obtain a list of devices under the control of the docking device class circuit. 



obtain a list of devices under the control of a general purpose I/O device under the 
control of the docking device class circuit 




operating system of a portable computer obtains driver code 
appropriate to the at least one device; in one implementation, this 
driver code is obtained from storage on-board the portable computer 
system, while in another implementation, this driver code is obtained 
from or through the device class docking circuit 




control the at least 
one device via 
commands 
appropriate to the 
bus 
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Fig. 9 




detect a docking device class circuit present on a bus, in one implementation, detecting a docking 
device class circuit present on a bus includes but is not limited to detecting an identification number 
reserved for the docking device class circuit (e.g., detecting a USB identification number) 




obtaining a bus description table from the docking device class circuit 



obtain a description of at least one Peripheral Component Interconnect bus resident within in a 
docking device, or at least one Universal Serial Bus resident within in a docking device, or at least 
one Accelerated Graphics Port Bus resident within in a docking device, or at least one AT bus 
resident within in a docking device. 




control the at least 
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commands 
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bus 



(stop) 
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detect a docking device class circuit present on a bus, in one implementation, detecting a docking 
device class circuit present on a bus includes but is not limited to detecting an identification number 
reserved for the docking device class circuit (e g., detecting a USB identification number) 
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obtain a description of at least one device in a docking 
station from the docking device class circuit 



control the at least one device via commands appropriate to the bus; in one implementation the bus to which the 
docking class device circuit is attached is a Universal Serial Bus; in one embodiment the bus to which the docking 
class device circuit is attached is a Peripheral Component Interconnect bus, and in one embodiment the bus to 
which the docking class device circuit is attached is an AT bus 



control the at least one device associated with 
docking 



controlling at least one power supply in a docking station 



activate a power supply 

having voltage 
appropriate to a portable 
computer system. 
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manufacture, or composition of matter, or an improvement thereof) which is claimed and for which a 
patent is sought by way of the application entitled 

Docking Device Class System and Method 
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I | was filed on as Application Serial No. 
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I acknowledge the duty to disclose information, which is material to patentability as defined in Title 
37, Code of Federal Regulations, § 1.56. 
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I hereby claim the benefit under Title 35, United States Code, § 120 of any United States 
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below and, insofar as the subject matter of each of the claims of this application is not disclosed in the 
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Filing Date 
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(44,047); Shireen Irani Bacon (40,494); Rory G. Bens (44,028); George Wolken, Jr. (30,441); John A. 
Odozynski (28,769); Paul E. Lewkowicz (44,870); Theodore P. Lopez (44,881); Eric Stephenson 
(38,321); Christopher Allenby (45,906); David C. Hsia (46,235); Mark J. Rozman (42,117); Margaret 
M. Kelton (44,182); Do Te Kim (46,231); Alex Chen (45,591); Monique M. Heyninck (44,763); 
Gregory J. Michelson (44,940); Jonathan Geld (44,702); Emmanuel Rivera (45,760); Jason FarHadian 
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Strawbrich (36,692); Rita Wisor (41,382) ; Gregory Powell (47,005); and Mark E. Schmidt (47,063). 
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